$(function(){
  const {form,laypage}=layui
  // 定义一个查询的参数对象，将来请求数据的时候，
  // 需要将请求参数对象提交到服务器
  var q = {
    pagenum: 1, // 页码值，默认请求第一页的数据
    pagesize: 2, // 每页显示几条数据，默认每页显示2条
    cate_id: '', // 文章分类的 Id
    state: '' // 文章的发布状态
  }

 // 定义美化时间的过滤器
  template.defaults.imports.dataFormat=function(date){
    const dt=new Date(date)
    let y=dt.getFullYear()
    let m=padZero(dt.getMonth()+1)
    let d=padZero(dt.getDate())
    let hh=padZero(dt.getHours())
    let mm=padZero(dt.getMinutes())
    let ss=padZero(dt.getSeconds())
    return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
  }
  // 定义补零的函数
  function padZero(n) {
    return n > 9 ? n : '0' + n
  }

  initTable()
  initCate()
  function initTable(){
    $.ajax({
      method:'GET',
      url:'/my/article/list',
      data: q,
      success:function(res){
        if(res.status!==0){
          return layer.msg(res.message)
        }
        // layer.msg(res.message)
        const htmlStr=template('tpl-table',res)
        $('tbody').html(htmlStr)

        renderPage(res.total)
      }
    })
  }

  function initCate(){
    $.ajax({
      method:'GET',
      url:'/my/article/cates',
      success:function(res){
        if(res.status!==0){
          return layer.msg(res.message)
        }
        const htmlStr=template('tpl-cate',res)
        $('[name=cate_id]').html(htmlStr)
        form.render()
      }
    })
  }

  $('#form-search').on('submit', function(e) {
    e.preventDefault()
    // 获取表单中选中项的值
    let cate_id = $('[name=cate_id]').val()
    let state = $('[name=state]').val()
    // 为查询参数对象 q 中对应的属性赋值
    q.cate_id = cate_id
    q.state = state
    // 根据最新的筛选条件，重新渲染表格的数据
    initTable()
  })

  function renderPage(total){
    laypage.render({
      elem: 'pageBox', // 分页 ID，不用加 # 号
      count: total, // 总数据条数
      limit: q.pagesize, // 每页显示几条数据
      curr: q.pagenum, // 设置默认被选中的分页
      layout: ['count','limit','prev', 'page', 'next','skip','refresh'],
      limits: [2,5,7,10], // 每页展示多少条
      jump: function(obj,first){
        // 把最新的页码值，赋值到 q 的 pagenum 属性中
        q.pagenum=obj.curr
        // 把最新的条目数，赋值到 q 的 pagesize 属性中
        q.pagesize=obj.limit
        if(!first){
          initTable()
        }
      }
    });
  }

  $('tbody').on('click','.btn-delete',function(){
    const len=$('.btn-delete').length
    let id=$(this).attr('data-id')
    layer.confirm('确认删除?', { icon: 3, title: '提示' }, function(index){
      $.ajax({
        method:'GET',
        url:'/my/article/delete/' + id,
        success:function(res){
          if(res.status!==0){
            return layer.msg(res.message)
          }
          layer.msg(res.message)
          if(len==1 && q.pagenum!==1){
            q.pagenum--
          }
          initTable()
        }
      })
      layer.close(index)
    })
  })
})